package com.ww.springboot.boot.algorithm.sort;

import com.ww.springboot.boot.algorithm.Utils;

/**
 * 选择排序
 * 每次在未排序的数组中选择最大/小值放在首部
 *
 * 空间交换最少  数据较少时可以使用
 *
 * @author wanwei
 * @since 2021-05-03 16:29
 */
public class SelectionSort {

    public static void main(String[] args) {
        int[] array = {3, 2, 3, 4, 5, 6, 7, 8, 9, 2};
        sort(array);
    }

    public static void sort(int[] array) {
        for (int i = 0; i < array.length; i++) {
            int max = i;
            for (int j = i + 1; j < array.length; j++) {
                if (array[j] > array[max]) {
                    max = j;
                }
            }
            int temp = array[i];
            array[i] = array[max];
            array[max] = temp;
            Utils.printfArray(array);
        }
    }
}
